home *** CD-ROM | disk | FTP | other *** search
/ Chip 2007 January, February, March & April / Chip-Cover-CD-2007-02.iso / Pakiet bezpieczenstwa / mini Pentoo LiveCD 2006.1 / mpentoo-2006.1.iso / livecd.squashfs / usr / include / linux / percpu.h < prev    next >
C/C++ Source or Header  |  2005-10-13  |  2KB  |  63 lines

  1. #ifndef __LINUX_PERCPU_H
  2. #define __LINUX_PERCPU_H
  3. #include <linux/gfp.h>
  4. #include <linux/spinlock.h> /* For preempt_disable() */
  5. #include <linux/slab.h> /* For kmalloc() */
  6. #include <linux/smp.h>
  7. #include <linux/string.h> /* For memset() */
  8. #include <asm/percpu.h>
  9.  
  10. /* Enough to cover all DEFINE_PER_CPUs in kernel, including modules. */
  11. #ifndef PERCPU_ENOUGH_ROOM
  12. #define PERCPU_ENOUGH_ROOM 32768
  13. #endif
  14.  
  15. /* Must be an lvalue. */
  16. #define get_cpu_var(var) (*({ preempt_disable(); &__get_cpu_var(var); }))
  17. #define put_cpu_var(var) preempt_enable()
  18.  
  19. #ifdef CONFIG_SMP
  20.  
  21. struct percpu_data {
  22.     void *ptrs[NR_CPUS];
  23.     void *blkp;
  24. };
  25.  
  26. /* 
  27.  * Use this to get to a cpu's version of the per-cpu object allocated using
  28.  * alloc_percpu.  Non-atomic access to the current CPU's version should
  29.  * probably be combined with get_cpu()/put_cpu().
  30.  */ 
  31. #define per_cpu_ptr(ptr, cpu)                   \
  32. ({                                              \
  33.         struct percpu_data *__p = (struct percpu_data *)~(unsigned long)(ptr); \
  34.         (__typeof__(ptr))__p->ptrs[(cpu)];    \
  35. })
  36.  
  37. extern void *__alloc_percpu(size_t size, size_t align);
  38. extern void free_percpu(const void *);
  39.  
  40. #else /* CONFIG_SMP */
  41.  
  42. #define per_cpu_ptr(ptr, cpu) (ptr)
  43.  
  44. static inline void *__alloc_percpu(size_t size, size_t align)
  45. {
  46.     void *ret = kmalloc(size, GFP_KERNEL);
  47.     if (ret)
  48.         memset(ret, 0, size);
  49.     return ret;
  50. }
  51. static inline void free_percpu(const void *ptr)
  52. {    
  53.     kfree(ptr);
  54. }
  55.  
  56. #endif /* CONFIG_SMP */
  57.  
  58. /* Simple wrapper for the common case: zeros memory. */
  59. #define alloc_percpu(type) \
  60.     ((type *)(__alloc_percpu(sizeof(type), __alignof__(type))))
  61.  
  62. #endif /* __LINUX_PERCPU_H */
  63.